Tue Aug 21 02:57:13 2001 Jonathan Blandford <jrb@redhat.com>>
authorJonathan Blandford <jrb@src.gnome.org>
Tue, 21 Aug 2001 06:59:55 +0000 (06:59 +0000)
committerJonathan Blandford <jrb@src.gnome.org>
Tue, 21 Aug 2001 06:59:55 +0000 (06:59 +0000)
* gtk/gtktreeview.c (gtk_tree_view_button_press): Fix up selection
a little.  More needs to be done tomorrow.

ChangeLog
ChangeLog.pre-2-0
ChangeLog.pre-2-10
ChangeLog.pre-2-2
ChangeLog.pre-2-4
ChangeLog.pre-2-6
ChangeLog.pre-2-8
gtk/gtktreeview.c
tests/testtreesort.c

index de7b83d603694895c305da978b9f79554588faee..4302f8a0f9bdc02dfdfcb5981cb9aeedeb5ca4fe 100644 (file)
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,8 @@
+Tue Aug 21 02:57:13 2001  Jonathan Blandford  <jrb@redhat.com>>
+
+       * gtk/gtktreeview.c (gtk_tree_view_button_press): Fix up selection
+       a little.  More needs to be done tomorrow.
+
 Tue Aug 21 00:45:55 2001  Jonathan Blandford  <jrb@redhat.com>
 
        * gtk/gtktreeview.c (gtk_tree_view_destroy): Grr... Get it right.
index de7b83d603694895c305da978b9f79554588faee..4302f8a0f9bdc02dfdfcb5981cb9aeedeb5ca4fe 100644 (file)
@@ -1,3 +1,8 @@
+Tue Aug 21 02:57:13 2001  Jonathan Blandford  <jrb@redhat.com>>
+
+       * gtk/gtktreeview.c (gtk_tree_view_button_press): Fix up selection
+       a little.  More needs to be done tomorrow.
+
 Tue Aug 21 00:45:55 2001  Jonathan Blandford  <jrb@redhat.com>
 
        * gtk/gtktreeview.c (gtk_tree_view_destroy): Grr... Get it right.
index de7b83d603694895c305da978b9f79554588faee..4302f8a0f9bdc02dfdfcb5981cb9aeedeb5ca4fe 100644 (file)
@@ -1,3 +1,8 @@
+Tue Aug 21 02:57:13 2001  Jonathan Blandford  <jrb@redhat.com>>
+
+       * gtk/gtktreeview.c (gtk_tree_view_button_press): Fix up selection
+       a little.  More needs to be done tomorrow.
+
 Tue Aug 21 00:45:55 2001  Jonathan Blandford  <jrb@redhat.com>
 
        * gtk/gtktreeview.c (gtk_tree_view_destroy): Grr... Get it right.
index de7b83d603694895c305da978b9f79554588faee..4302f8a0f9bdc02dfdfcb5981cb9aeedeb5ca4fe 100644 (file)
@@ -1,3 +1,8 @@
+Tue Aug 21 02:57:13 2001  Jonathan Blandford  <jrb@redhat.com>>
+
+       * gtk/gtktreeview.c (gtk_tree_view_button_press): Fix up selection
+       a little.  More needs to be done tomorrow.
+
 Tue Aug 21 00:45:55 2001  Jonathan Blandford  <jrb@redhat.com>
 
        * gtk/gtktreeview.c (gtk_tree_view_destroy): Grr... Get it right.
index de7b83d603694895c305da978b9f79554588faee..4302f8a0f9bdc02dfdfcb5981cb9aeedeb5ca4fe 100644 (file)
@@ -1,3 +1,8 @@
+Tue Aug 21 02:57:13 2001  Jonathan Blandford  <jrb@redhat.com>>
+
+       * gtk/gtktreeview.c (gtk_tree_view_button_press): Fix up selection
+       a little.  More needs to be done tomorrow.
+
 Tue Aug 21 00:45:55 2001  Jonathan Blandford  <jrb@redhat.com>
 
        * gtk/gtktreeview.c (gtk_tree_view_destroy): Grr... Get it right.
index de7b83d603694895c305da978b9f79554588faee..4302f8a0f9bdc02dfdfcb5981cb9aeedeb5ca4fe 100644 (file)
@@ -1,3 +1,8 @@
+Tue Aug 21 02:57:13 2001  Jonathan Blandford  <jrb@redhat.com>>
+
+       * gtk/gtktreeview.c (gtk_tree_view_button_press): Fix up selection
+       a little.  More needs to be done tomorrow.
+
 Tue Aug 21 00:45:55 2001  Jonathan Blandford  <jrb@redhat.com>
 
        * gtk/gtktreeview.c (gtk_tree_view_destroy): Grr... Get it right.
index de7b83d603694895c305da978b9f79554588faee..4302f8a0f9bdc02dfdfcb5981cb9aeedeb5ca4fe 100644 (file)
@@ -1,3 +1,8 @@
+Tue Aug 21 02:57:13 2001  Jonathan Blandford  <jrb@redhat.com>>
+
+       * gtk/gtktreeview.c (gtk_tree_view_button_press): Fix up selection
+       a little.  More needs to be done tomorrow.
+
 Tue Aug 21 00:45:55 2001  Jonathan Blandford  <jrb@redhat.com>
 
        * gtk/gtktreeview.c (gtk_tree_view_destroy): Grr... Get it right.
index 92ff76408afe5767e81b89b56894e9405db96ae5..aa2f1debd792ead4fbbb078d597bdcff00f61abf 100644 (file)
@@ -1657,7 +1657,20 @@ gtk_tree_view_button_press (GtkWidget      *widget,
           tree_view->priv->press_start_y = event->y;
         }
 
-      gtk_tree_view_real_set_cursor (tree_view, path, TRUE);
+      if (tree_view->priv->in_free_motion)
+       {
+         gtk_tree_view_real_set_cursor (tree_view, path, FALSE);
+         gtk_tree_view_real_toggle_cursor_row (tree_view);
+       }
+      else if (tree_view->priv->in_extended_selection)
+       {
+         gtk_tree_view_real_set_cursor (tree_view, path, FALSE);
+         gtk_tree_view_real_select_cursor_row (tree_view);
+       }
+      else
+       {
+         gtk_tree_view_real_set_cursor (tree_view, path, TRUE);
+       }
       
       if (event->button == 1 && event->type == GDK_2BUTTON_PRESS)
        {
@@ -1670,8 +1683,8 @@ gtk_tree_view_button_press (GtkWidget      *widget,
                gtk_tree_view_real_collapse_row (GTK_TREE_VIEW (widget), path,
                                                 tree, node);
            }
-         gtk_tree_view_row_activated (tree_view, path, column);
 
+         gtk_tree_view_row_activated (tree_view, path, column);
        }
       gtk_tree_path_free (path);
       return TRUE;
index 41e9decc76b5f210497837866f05b2228a385f06..a6c7d14fbe36ab432cd4ec53d9a4495f39998859 100644 (file)
@@ -69,6 +69,8 @@ main (int argc, char *argv[])
   //  gtk_tree_sortable_set_sort_column_id (GTK_TREE_SORTABLE (model), 0, GTK_TREE_SORT_ASCENDING);
   g_print ("start model\n");
   tree_view = gtk_tree_view_new_with_model (model);
+  gtk_tree_selection_set_mode (gtk_tree_view_get_selection (GTK_TREE_VIEW (tree_view)),
+                              GTK_TREE_SELECTION_MULTI);
   for (j = 0; j < 2; j++)
     for (i = 0; data[i].word_1 != NULL; i++)
       {